package ace.module.product.api.model.dto;

import io.swagger.v3.oas.annotations.media.Schema;

import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;
import lombok.experimental.SuperBuilder;

import jakarta.validation.constraints.*;
import jakarta.annotation.Nullable;
import java.io.Serializable;

/**
* 商品详情 data transform object.
*
* @author Caspar
*/
@Data
@SuperBuilder
@NoArgsConstructor
@AllArgsConstructor
@Schema(title = PmsProductDetailDto.TABLE_DESC)
public class PmsProductDetailDto implements Serializable {

  public static final String TABLE_NAME = "pms_product_detail";
  public static final String TABLE_DESC = "商品详情";
  public static final String ID_COLUMN_NAME = "id";
  public static final String ID_TITLE = "id";
  public static final String ID_DESC = "";
  public static final String PMS_APP_ID_COLUMN_NAME = "pms_app_id";
  public static final String PMS_APP_ID_TITLE = "商品应用id";
  public static final String PMS_APP_ID_DESC = "0=null";
  public static final String PRODUCT_ID_COLUMN_NAME = "product_id";
  public static final String PRODUCT_ID_TITLE = "商品id";
  public static final String PRODUCT_ID_DESC = "0=null";
  public static final String PRODUCT_SKU_ID_COLUMN_NAME = "product_sku_id";
  public static final String PRODUCT_SKU_ID_TITLE = "商品sku id";
  public static final String PRODUCT_SKU_ID_DESC = "0=null";
  public static final String TYPE_COLUMN_NAME = "type";
  public static final String TYPE_TITLE = "详情类型";
  public static final String TYPE_DESC = " 1-商品详情-默认 2-商品详情-电脑端 3-商品详情-移动端 100-商品SKU详情-默认 101-商品SKU详情-电脑端 102-商品SKU详情-移动端";
  public static final String DETAIL_COLUMN_NAME = "detail";
  public static final String DETAIL_TITLE = "详情 html格式";
  public static final String DETAIL_DESC = "";
  public static final String SORT_COLUMN_NAME = "sort";
  public static final String SORT_TITLE = "排序";
  public static final String SORT_DESC = "";
  public static final String DELETE_FLAG_COLUMN_NAME = "delete_flag";
  public static final String DELETE_FLAG_TITLE = "删除标识";
  public static final String DELETE_FLAG_DESC = "0-未删除";
  public static final String CREATE_TIME_COLUMN_NAME = "create_time";
  public static final String CREATE_TIME_TITLE = "创建时间";
  public static final String CREATE_TIME_DESC = "单位-毫秒";
  public static final String UPDATE_TIME_COLUMN_NAME = "update_time";
  public static final String UPDATE_TIME_TITLE = "更新时间";
  public static final String UPDATE_TIME_DESC = "单位-毫秒";
  public static final String ROW_VERSION_COLUMN_NAME = "row_version";
  public static final String ROW_VERSION_TITLE = "版本号和乐观锁";
  public static final String ROW_VERSION_DESC = "";

  @Schema(title = ID_TITLE, description = ID_DESC)
  private Long id;

  @Schema(title = PMS_APP_ID_TITLE, description = PMS_APP_ID_DESC)
  private Long pmsAppId;

  @Schema(title = PRODUCT_ID_TITLE, description = PRODUCT_ID_DESC)
  private Long productId;

  @Schema(title = PRODUCT_SKU_ID_TITLE, description = PRODUCT_SKU_ID_DESC)
  private Long productSkuId;

  @Schema(title = TYPE_TITLE, description = TYPE_DESC)
  private Integer type;

  @Schema(title = DETAIL_TITLE, description = DETAIL_DESC)
  private String detail;

  @Schema(title = SORT_TITLE, description = SORT_DESC)
  private Long sort;

  @Schema(title = DELETE_FLAG_TITLE, description = DELETE_FLAG_DESC)
  private Long deleteFlag;

  @Schema(title = CREATE_TIME_TITLE, description = CREATE_TIME_DESC)
  private Long createTime;

  @Schema(title = UPDATE_TIME_TITLE, description = UPDATE_TIME_DESC)
  private Long updateTime;

  @Schema(title = ROW_VERSION_TITLE, description = ROW_VERSION_DESC)
  private Long rowVersion;

}